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COPYRIGHT NOTICE 
A portion of the disclosure of this patent document 
contains material which is subject to copyright protection. 
The copyright owner has no objection to the xerographic 
10 reproduction by anyone of the patent document or the patent 
disclosure in exactly the form it appears in the Patent and 
Trademark Office patent file or records, but otherwise 
reserves all copyright rights whatsoever. 

15 BACKGROUND OF THE INVENTION 

The present invention relates to the field of 
customized information presentation. More specifically, one 
embodiment of the invention provides a custom page server 
which can quickly serve custom pages and is scalable to handle 

2 0 many users simultaneously. 

Web servers for serving static documents ("Web 
pages") over the global Internet are known. While static 
documents are useful in many applications where the 
information to be presented to each requesting user is the 

25 same, some applications require customization to appeal to 

users. For example, in presenting news to users, custom pages 
present new£;/which is more relevant to the requesting users 
than static pages. With static pages, a user will often have 
to scroll through many topics not of interest to that user to 

30 get to the information of interest. With custom pages, the 
information is filtered according to each user's interest. 

Customizing a server response based on the requestor 
is known, however known systems do not scale well . One method 
of serving custom pages is to execute a script, such as a CGI 

35 (Common Gateway Interface) script, or other program to collect 
the information necessary to generate the custom page. For 
example, if the custom page is a news page containing stock 
quotes, sports scores and weather, the script might poll a 
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quote server to obtain the quotes of interest, poll a sports 
score server to obtain the scores of interest and poll a 
weather server to obtain the weather. With this information, 
the server generates the custom page and returns it to the 
5 user. This approach is useful where there are not many 
requestors and where the attendant delay is acceptable to 
users. While it may be the case that current users are 
willing to wait while pages load in their browsers, growing 
impatience with waiting will turn users away from such 
10 servers, especially as use increases. 

One approach to avoiding long waits is to transfer 
the custom information in non-real- time , so that the 
information is stored local to the user as it arrives and is 
presented to the user on request. A disadvantage of such a 
15 system is that the networks used by the user become clogged 
with data continually streaming to the user and require large 
amounts of local storage. Another disadvantage is that the 
locally stored information will become out of date as the 
server receives new data. 
2 0 From the above it is seen that an improved system 

for delivering custom pages is needed. 
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SUMMARY OF THE INVENTION 
An improved custom page server is provided by virtue 
of the present invention. In one embodiment, user preferences 
5 are organized into templates stored in compact data structures 
and the live data used to fill the templates is stored local 
to the page server which is handing user requests for custom 
pages. One process is executed on the page server for every 
request. The process is provided a user template for the user 

10 making the request, where the user template is either 

generated from user preferences or retrieved from a cache of 
recently used user templates. Each user process is provided 
access to a large region of shared memory which contains all 
of the live data needed to fill any user template'. Typically, 

15 the pages served are news pages, giving the user a custom 
selection of stock quotes, news headlines, sports scores, 
weather, and the like. With the live data stored in a local, 
shared memory, any custom page can be built within the page 
server, eliminating the need to make requests from other 

20 servers for portions of the live data. While the shared 
memory might include RAM (random access memory) and disk 
storage, in many computer systems, it is faster to store all 
the live data in RAM. 

If the volume of requests becomes too great for one 

25 page server to handle, the system is easily scaled by adding 
additional page servers. Each page server maintains its own 
copy of p the live data in its shared me_mpry, and needs to 
maintain only the user templates for the requests it is 
handling, so no communication between page servers is needed. 

3 0 A further understanding of the nature and advantages 

of the inventions herein may be realized by reference to the 
remaining portions of the specification and the attached 
drawings . 

3 5 BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram of a client-server 
architecture according to one embodiment of the present 
invention; 
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FIG, 2 is a schematic diagram showing how a user's 
custom page is generated from a user configuration, a global 
template and live data . 

FIG. 3 is an illustration of a global front page 
5 template as might be used to generate user templates. 

FIG. 4 is an illustration of a user template 
generated from the global front page template of FIG. 3 as 
might be used to generate a custom user page . 

FIG. 5 is an illustration of a user page generated 
10 using the global template of FIG. 4. 

FIG. 6 is an illustration of how intelligent 
defaults are selected. 

Two appendices are included at the end of this 
description. Appendix A is a full listing of the user 
15 template shown in part in FIG. 4. Appendix B is an HTML source 
code listing of the HTML page used to generate the browser 
display shown in FIG. 5. 



DESCRIPTION OF THE PREFERRED EMBODIMENTS 
20 FIG. 1 shows a client- server system 100 which is 

used to display custom news pages. A custom news page is 
displayed on a browser 102 which obtains the page from a page 
server 104 via Internet 106. While only one browser 102 is 
shown, a typical system will have many browsers connecting and 
25 disconnecting to the system. 

The art of client -server systems using HTTP 
(HyperText Transport Protocol) messaging or other protocols is 
well known and will not be addressed in detail here. 
Essentially, browser 102 makes a request for a particular page 
3 0 by specifying a Uniform Resource Locator {"URL") for the page. 
In the example shown in FIG. 1, the request is directed to 
the URL "http : /my .yahoo . com/" . Normally, this URL is directed 
to the root directory of a machine named my.yahoo.com. As is 
the convention in Internet communications, browser 102 submits 
3 5 the domain portion ("my.yahoo.com") of the URL to a name 
server, such as name server 108, to determine an actual 
address for the page server 104. Name server 108 returns an 
IP (Internet Protocol) address to browser 102 directing it to 
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a page server 104. Where multiple page seirvers 104 are used, 
name server 108 returns IP addresses in a round-robin fashion 
to distribute the load over multiple page servers . 
Alternatively, name server 108 might distribute the load more 
5 deterministic by tracking browser addresses and hashing the 
browser address to select a page server 104. It is 
deterministic in that any given browser always accesses the 
same page server 104. This allows for more efficient caching 
of user templates, since more cache hits are likely where a 

10 given browser always returns to one page server. 

When a page server receives the URL for its root 
directory, it interprets that as a request for the user's 
custom summary page. The user is determined not from the URL, 
but from a "cookie" provided by browser 102 with the URL. 

15 Cookies are strings of data stored by browsers and sent along 
with any request to a URL having a domain associated with the 
cookie . 

Page servers 104 obtain the 1 ive data from many 
disparate sources and reformat the data into a form suitable 

2 0 for use by the page server. Page servers 104 are coupled, via 
a network, to edit servers 112, which are used when a user 
changes his or her user template. The user templates are 
stored in a user configuration database 116 and are stored and 
provided to edit servers by a network appliance 114 written 

25 for this purpose. Network appliance 114 is a process tuned to 
quickly locate files in large directories (N400 
files/directory) and return them to the edit seirvers or page 
servers. One embodiment of network appliance 114 is the F33 0 
fault-tolerant scalable server supplied by Network Appliance, 

30 of Mountain View, California. 

In a specific embodiment, page servers 104 are 
microcomputers running the Unix® operating system with 64 to 
128 megabytes of shared memory, page servers 104 and edit 
servers 112 are coupled using TCP/IP (Transport Control 

35 Protocol/Internet Protocol) and the user configuration 

database 116 is a Unix file structure which stores each user 
configuration in a text file. The particular file used by a 
user is a combination of the user's user name and a hash 
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result, to allow for quick access when many user 
configurations are stored. For example, the user 
configuration for summary "front" page for a user "ash802" 
might be stored at /de/13/y . ash802 , where "de" and "13" are 
5 hash results of a hash of the user name "ash802". 

FIG. 2 shows in more detail the generation of a 
custom page for a user, using a front page generator 200 and 
page server 104. Front page generator 200 generates a user 
template 202 from a global front page template 204 and a user 
10 configuration record 206. FIG. 3 shows an example of a global 
front page template. User configuration record 206 is a 
record selected from user configuration database 116. The 
record might have been obtained from a cache, but in the 
preferred embodiment, the records are not cached, the user 
15 templates are. 

Page server 104 is shown comprising a page generator 
210, a shared memory 212 for storing live data and a cache 214 
for caching user templates such as user template 202. Page 
generator 210 generates a custom front page 218 from a user 
20 template and the live data stored in shared memory 212. 

Although not shown, custom pages other than the front page can 
be generated in a similar fashion. Using user templates and a 
shared memory for the live data, page server 104 can quickly 
build custom pages in response to a user request. Where the 
25 user template is cached, the page can be generated entirely 
within page server 104 . 

Shared memory 212 is organized as a set of memory 
mapped files. With memory mapped files, the operating system 
maintains the data in permanent storage, but permanently 
30 caches the files in shared memory 212. This allows for quick 
recovery should a page server crash, since all of the shared 
memory can simply be reloaded from the permanent storage. 
This is a great feature from a user convenience standpoint, 
since the user will never be faced with a situation where they 
3 5 have to wait for a server to rebuild a page for them by 

querying the various data providing servers, such as sports 
server 230, stock server 232 and news server 234. As should 
be apparent from this description and FIG. 2, page generator 
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210 can generate custom front page 218 much more quickly using 
shared memory 212 as compared with using servers 23 0, 232, 234 
and page . template 202, One reason for this is that the time 
it takes to retrieve data from shared memory 212 does not 
5 appreciably increase relative to the bandwidth delay time when 
more data is retrieved. For example, if stock server 232 were 
queried for each individual stock quote, a page with fifty 
stock quotes might take ten times as long to generate as a 
page with five stock quotes. 

10 One aspect of the present invention is the 

realization that every piece of information a person can 
request on a page is storable in a shared memory closely 
coupled to a page generator. For example, page server 104 
shown in FIG. 2 can accommodate 65,000 different symbols for 

15 which quotes are provided. In one embodiment, all of the 

stock information for all 65,000 symbols is stored in a 13 to 
14 megabytes section of the shared memory. Where shared 
memory 212 is a 64MB or 128MB memory, this leaves sufficient 
room for other data, such as news headlines, sport scores, and 

20 memory used by the operating system for each process running 
on page server 104. In some embodiments, shared memory 212 is 
large enough to also accommodate more than just news 
headlines. For example, news summaries (as described further 
in connection with FIG. 5) can be stored in shared memory 212 

25 for quick access. 

As shown in FIG. 2, the user's front page template 
2,0,2 does not need '^o be generated each time, but rather is 
stored in cache 214. In a preferred embodiment, user 
templates are stored in cache 214 for long enough to be 

3 0 reused. Some users might choose to access their front page 
only infrequently, while others might choose to access their 
front page hourly. Since the pages are customized and 
dynamic, the user would see different information each time, 
but the same user template would be used each time. Of 

3 5 course, when the user edits his or her template, any cached 
copy of a user template is flushed. A garbage-collection 
process may also flush the cache of user pages which have been 
inactive for several days. In one implementation, cache 214 
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would accommodate 60,000 to 70,000 user templates. Where a 
particular page server is assigned on a random round robin 
basis, multiple page servers may cache their own copy of a 
given user template, but where a user is directed always to a 
5 particular server (except in the case where the particular 

server fails and a secondary server is used) , that page server 
will be the only one which needs to cache that users user 
template. Even where the round robin name server scheme is 
used, some browsers may cache IP addresses, even longer than 

10 the specified "time to live" variable associated with the IP 
address, in order to save the time required to obtain an IP 
address each time. With such a browser, the user is 
effectively directed to the same page server each time and the 
server side of the page serving system does not need to direct 

15 users to particular page servers. With newer browsers, 
however, the "time to live" variable is honored and new 
requests are made for IP addresses after the "time to live" 
has expired. In these cases, if the assignment of a user to a 
single page server is desired, name server 108 (see FIG. 1) 

20 will use the user name from the provided cookie or the user's 
IP address to assign a page server based on a hash of the user 
name or IP address . 

FIG. 3 is an illustration of global user template 
204. Global user template 204 is an HTML (HyperText Markup 

2 5 Language) document with additional tags as placeholders for 

live data. Several placeholders 3 02 are shown in FIG. 3. 

FIG. 4 is an illustration of user template n202 as 
might be generated from global user template 204 (see Fig. 3) 
and a user configuration record 206. A full listing of user 
30 template 202 is included herewith in Appendix A. User 

template 202 is determined by the user configuration and is 
independent of the live data, therefore it can be cached 
without needing to be updated, unless the user chooses to edit 
the configuration information. Preferably, the user templates 

3 5 are cached rather than the user configuration, to save a step 

and reduce the time to respond to a request for the page. 
Caching is more effective where the typical user makes several 
requests in a short time span and then doesn't make any 
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requests for a long period of time. 

Essentially, user template 202 contains the 
information about the user which does not change until the 
user changes his or her preferences'. Of course, the system 
5 operator could choose to make changes to how the system 

operates, thus requiring changes to the user preferences and 
user templates. User template 202 is shown comprising 
internal variables such as a time zone and demographic 
information. The demographic information, on the second line 

10 in FIG. 4 is used for selection of an advertisement which will 
be part of the custom page. In this example, the 
advertisement is targeted by the demographic information in 
the user template M, 85 , 95035 , T, * " indicating that a suitable 
ad should be targeted to a male user, age 85, located in zip 

15 code 95035, etc. As shown, the portfolio section contains 
selected stock symbols, the scoreboard section contains 
selected team symbols, and the weather section contains 
selected weather cities/zip codes. 

The selections of stock quote symbols, team scores, 

20 and weather cities are set by the user. In a preferred 

embodiment, intelligent defaults are selected by the system 
prior to user selection, so that users unfamiliar with the 
customization process will nonetheless be able to view non 
empty custom pages. This is described in further detail below 

25 in connection with FIG. 6.. 

FIG. 5 is an illustration of a user front page 218 
f - returned, by page server 104. User front page. 218 as shown f.n 

FIG. 5 includes many elements, some of which are described 
here in further detail. User front page 218 is built 

3 0 according to a user template and live data. The user template 
specifies, for example which quotes are shown in the portfolio 
module, which cities are displayed in the weather module, etc. 

Each of the modules 504 can be customized by a user and moved 
about front page 218. The modules 504 are also reusable, in 

35 that any customized module which appears on multiple pages can 
be edited from any one of those pages and the edits will be 
reflected on each of the pages. Other custom pages for the 
user can be viewed by selecting one of the page buttons 502 
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appearing below the header. Other pages and utilities can be 
selected using the buttons 508 which are part of the header. 

In addition to all of the live date shown in FIG. 5 
being stored in the shared memory, summaries from each of the 
5 major news topics can also be stored in the shared memory and 
viewed by pressing on the news topic header, such as news 
topic header 506. As should be noted, the page generator can 
also intelligently display dates 510 customized for a 
particular user, using a time zone variable in the user 
10 template. This time zone variable is shown as the first line 
in user template 202 in FIG. 4. In addition to being able to 
modify each of the modules, in many cases the order of 
appearance of the modules is customizable. For example, the 
order of the various sections of user template 2 02 shown in 
15 FIG. 4 is not fixed. 

The preference editing process can be initiated by . 
the user pressing the appropriate edit button 512 . As 
explained above, once the editing process is complete, the 
user template is flushed from the cache and regenerated. 
20 Since each of the news stories is essentially a static page 
linked to a headline shown in the news section, these can 
simply be linked to static pages on a news seirver. 

Referring now to FIG. 6, an illustration of 
intelligent defaulting for populating a user template, and 
25 consequently a user summary page. As part of a registration 
process, a user indicates, among other things, his or her zip 
code. This zip code is used to locate an approxi-mate 
longitude and latitude for the user using a zip code lookup 
table 602. This allows the user*s location to be located on a 
30 map 604. Map 604 provides city boundaries and, with team 

location table 606, also provides locations for various sports 
teams which can be selected in a sports module. In selecting 
a default predetermined number of cities and sports teams for 
inclusion as initial selections for a particular user, a 
3 5 circle is drawn around the user and increased in diameter 

until the circle envelopes a suitable predetermined number of 
cities and sports teams. In this way, each user is guaranteed 
a default number of nearby teams and cities for sports and 
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weather, respectively. While this assumes that the user is 
interested in only the teams nearest the user, the system can 
be arranged to provide intelligent defaults where geographic 
anomalies are known to exist. Geographic anomalies occur in 
5 communities which have more loyalty to distant teams than 
nearby teams, such as might occur when the distant team is 
much better than the nearby team or when the nearby team 
recently moved to a distant location. In any case, the user 
is allowed customize his or her pages beginning with the 
10 intelligent defaults selected. 

Other intelligent defaults can be provided in other 
contexts. For example, the header of user front page 218 
includes a button 508 labelled "myweb" which, when pressed, 
would lead the user to a custom listing of web sites. The 
15 initial defaults for that custom listing of web sites might be 
generated based on the keywords of interest to that user or 
based on the news topics, sports teams or weather cities 
selected by the user. 

The above description is illustrative and not 
20 restrictive. Many variations of the invention will become 
apparent to those of skill in the art upon review of this 
disclosure. The scope of the invention should, therefore, be 
determined not with reference to the above description, but 
instead should be determined with reference to the appended 
25 claims along with their full scope of equivalents. 
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Appendix A. Listing of a User Template 

<! — timezone : -8 , PT 0 — > 
<!-- ad:M, 85, 95035, T, * 792 — > 
5 <! — 

portfolio : Quotes, pf_l, 1, '^DJI, "NYA, "IXIC, "^SPX, ^XAX, YHOO, NSCP, lOM, NSCP, YHOO 
2836 --> 

< ! — 

scoreboard: NCAAFSSC, NHLSAN, MLSSAN , NCAAFSSS , ALOAK, NBAGSW, NFLOAK, NCAAFCCD, NF 
10 LSFO,NLSFO 3803 — > 

<! — weather: f, 30901, uk_londo, 94601, 95101 4368 — > 

< ! — 

mode_bar: "FRONT_PAGE" , . hier=News + Suminary% 3aEdit & .done^http: //my. yahoo, com/ 
news/summary . html?v 4538 --> 
15 <! — sximmary2 : 3, rt , rw, zOOOO, mlb, re, vf 4597 — > 
<! — motd: us_motn.html 4 696 — > 
<html> 
<head> 

<title>My Yahoo! news summary for ash802</t it le> 
20 </head> 
<body> 

<center> 

<map name="top"><area shape=rect coords = "0, 0, 45 , 66" 
25 href ="/news/summary . html?v"><area shape=rect coords="4 5 , 0 , 90, 66" 

href="/internet/directory .html?v"><area shape=rect coords = "90, 0, 135, 66" 
href ="/contacts/white_pages . html?v"><area shape=rect coords="135, 0,34 6,66" 
href ="/?myHome"><area shape=rect coords="346, 0, 389, 66" 

href ="/help/news/summary . html"><area shape=rect coords="389, 0, 431, 66" 
3 0 href ="http : //edit .my . yahoo . com/conf ig/eval_prof ile "Xarea shape-rect 
coords="4 31, 0, 4 77, 66" href="http: //edit . my . yahoo . com/conf ig/tof fly" > 
</map> " _ r. 

<center><a href ="/bin/top_menu"><img border=0 height=62 width=477 ismap 
usemap="#top" src="http : //www . yahoo . com/ image s/my/banner /news 1 . gif " 
35 alt="My Yahoo ! "></a></center> 

<P> 

<center><form action="http : / /search. my . yahoo. com/search/my"> <font 
si2e-"-2">[ <a 

4 0 href ="http : / /edit . my. yahoo . com/conf ig/set_attr?attr=sloc&value=b& . done=htt 
p: //my. yahoo . com/news/summary . html? v">move to bottom</a> ] </font><input 
si2e=25 name=p> <font size="-l">  <input type=submit 
value=Search><input type-hidden name=n value=^"25">   <a 
href ="http : / / search , my .yahoo . com/ search /my/ opt ions ">Options</a></font></fo 

4 5 rm></center><p> 
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<center> 

<table border^O cellspacing=0 cellpadding=2> 
<tr> 

<td align=center><f ont 
5 color="#000000"><b>Sections : </b>    </f ont></td> 
<td align=center bgcolor=" #dcdcdc"><f ont 
color="#000000"><b>Front  Page</b></f ont ></td> 
<td>  | </td> 

<td align=center><a href ="/news/business/summary . html?v">Business</a></td> 
10 <td>  1   </td> 
<td align=center><a 

href=" /news /port folio_suinmary . html?v">Port folios </a></td> 
<td>  | </td> 
<td align=center><a 
15 href=" /news /entertainment /summary . html?v">Entertainment </a></td> 
<td>  l </td> 

<td align=center><a href /news /sports /summary . html?v'* >Sports</a></td> 
<td>  | </td> 
<td align=center><a 
2 0 href =" /news/technology /summary . html? v">Technology</a></td> 
</tr> 
</table> 
</center> 
</center> 

25 <table border=l cellpadding=4 cellspacing=0 width==" 100% "> 
<tr><td align=center valign=top width="l%"> 
<a 

href ="http : / /edit . my . yahoo . com/conf ig/eval_lef t ?mode=lef t_nsum& . done=http% 
3a%2f %2fmy%2eyahoo%2ecom%2fnews%2f summary%2ehtmi%3fv"><img border=0 
3 0 src="http: //www. yahoo. com/ images /my/ left . gif " alt^"edit lef t "></a> 
<table border=0 cellpadding^l cellspacing=0 width="100% "> 
<tr bgcolor="#dcdcdc"><td colspan=4 width="100% "xtable border^O 
cellpaading^2 cellspacing=0 width="100% "xtrxtd width="100% "><b><f ont 
size="+l">P<font size="+0">ORTFOLIOS</f ont ></ font ></b></td><td 

3 5 align=right><a 

href ="http: / /edit . my. yahoo . com/conf ig/eval_quotes? . done=htt:p : //my. yahoo . co 
m/news/summary .html?v"><img align=absmiddle border=0 height=13 width=25 
src="http: //www. yahoo . com/images/my/personalize . gif " 
alt="edit"></a></td></tr></table></td></tr> 

4 0 <tr><td align=center colspan^4 ><f orm method=get 

action=="http : //quote . yahoo, com/quotes "><f ont size="-l " xinput type=^text 
size=10 name==symbols>< input type=^submit value="Get Quotes "xbrxf ont 
size="0">quotes delayed 20 minutes - <a 

href="/fin_disclaimer .html">disclaimer</a><br>click on symbol for detailed 
45 quote + news<br><b>*</b> indicates new news during last 
24hrs<f ontx/f orm></td></tr></table> 
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<hr size=0><table border=0 cellpadding=l cellspacing=0 width="100%"> 
<tr bgcolor="#dcdcdc"><td colspan=5 width=" 100% "xtable border=0 
cellpadding=2 cellspacing=0 width="100% "xtrxtd width=" 100% "><a 
href="/sum/?http: //sports . yahoo . com/" ><b>< font size="+l ">S<f ont 
5 si2e="+0">COREBOARD</font></font></b></a></td><td align-right ><a 

href="http: / /edit .my . yahoo . com/config/ set_sports? . done=http : / /my . yahoo . com 
/news/summary . html?v"><img align=absmiddle border=0 height=13 width=25 
src="http : //www. yahoo . com/ images /my /personalize . gif " 
alt=="edit"></a></td></tr></table></td></tr> 

10 

<hr si2e=0><table border=0 cellpadding=2 cellspacing-0 width-"100%"> 
<tr bgcolor="#dcdcdc"><td colspan=3 width=" 100% "xtable border=0 
cellpadding-2 cellspacing=0 width=" 100% "xtrxtd width=" 100% " xa 
href-"/my/?http: / /weather . yahoo . com/ " xbxf ont si2e=" + l ">W<f ont 

15 size=" + 0">EATHER</font></font></bx/a></tdxtd align=right><a 

href ="http : / /edit .my . yahoo . com/conf ig/set_wni? . done=http : / /my . yahoo . com/ne 
ws/suinmary.html?v"><img align=absmiddle border=0 height=13 width=25 
src="http : / /www. yahoo . com/ images /my /personalize .gif" 
alt="edit"x/a></td></tr></tablex/td></tr> 

20 <tr><td align=center colspan=3><f ont size=0>click on city for extended 
f orecast</font></tdx/tr> 
</table> 

<hr size=0> 
25 <px/td> 

<td align=center valign=top width="100% "> 

<table border=l cellpadding=2 cellspacing=0 width=" 100% " > 
</table> 

30 

</tdx/tr> 
</table> 

3 5 <center> 

<tabie border=l cellpadding=2 cellspacing^O width=" 100% "> 

</table> 
</center> 

40 

<P> 
<hr> 

<center> 

<table border=0 cellpadding=0 cellspacing^O width=" 100% "> 
45 <tr> 

<td align=left valign=top><table border=0 cellpadding==0 cellspacing=0> 
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<tr><td align=left valign=bot tomxa href="/iny/?http: //www. yahoo. com/"><img 
borcier=0 height=47 width=47 src="http : //www . yahoo . com/images/my/yahoo . gif" 
alt-"Yahoo! "></a></td> 
<td>    </td> 
5 <td align^left valign^bottom width="100% "><f ont size="-l "><i>Copyright 
© 1994-1997 Yahoo! Inc. All rights reserved .< /i><br>Port ions 
copyright © 1997 Reuters Ltd. All rights reserved . <br> 
Portions copyright © 1997 SportsTicker Enterprises LP. All rights 
reserved. <br> 

10 Portions copyright © 1997 Weathernews Inc. All rights reserved. <br> 
Portions copyright © 1997 Business Wire, All rights reserved. <br> 
Portions copyright © 1997 PR Newswire. All rights reserved . <br> 
Questions, comments, or suggestions? Send us <a 

href=^"http: / /my. yahoo . com/ feedback . html ">f eedback</a> , </f ont></td> 
15 </tr> 

</table> 
</td> 

<td>    </td> 

<td align=^right><a href =" /bin/logout_menu"><img border=0 height = 68 
20 width=100 ismap usemap=" #logout " 

src="http : //www. yahoo . com/ images /my/ logout . gif " alt= "Change 

User"></a></td> 

</tr> 

</table> 
25 </center> 

<map name=logout> 

<area coords-"0 , 0, 50, 68 " href =" /my/?http : //www . yahoo . com/ "> 
<area coords="51, 0, 100, 68 " 

href="http: //edit .my . yahoo. com/conf ig/login?logout=l "> 
3 0 </map> 

</body> 

</html> ^ 
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Appendix B. Listing of a U ser Page 

<html> 
<head> 

5 <title>My Yahoo! news summary for ash802</title> 
</head> 
<body> 

<center> 

10 <map name="top'*><area shape=rect coords = "0 , 0, 45, 66" 

href=*"/news/suinmary.html?v"><area shape^rect coords="4 5, 0 , 90 , 66" 
href="/internet/directory.html?v"><area shape=rect coords="90, 0, 135, 66" 
href="/contacts/white_pages .html?v"><area shape=rect coords=" 135 , 0 , 346, 66" 
href="/?myHoine"><area shape=rect coords="34 6, 0 , 389, 66" 

15 href="/help/news/suinmary.html"><area shape=rect coords="389 , 0 , 431 , 66" 
href="http: //edit. my. yahoo.com/config/eval_prof ile"><area shape=rect 
coords="431, 0, 477, 66" href ="http :/ /edit .my . yahoo . com/config/toffly"> 
</map> 

<center><a href =" /bin/top_menu"><img border=0 height=62 width=477 ismap 
20 usemap="#top" src-"http : //www . yahoo . com/ images /my/banner/newsl . gif" alt="My 
Yahoo! "></a></center> 

<font size="-5"><p></f ontx ! — SpaceID=0 noad — > 

<font size="-5"><p></font> 
25 <p> 

<center><form action="http :/ /search . my . yahoo . com/search/my"> <font si2e-"-2">[ <a 
href="http: //edit .my . yahoo . com/conf ig/set_attr?attr=sloc&value=b& . done=http: //my . y 
ahoo. com/news/summary. html?v">move to battom</a> ] </font><input size=25 name=p> 
<font size-"-l">  <input type=submit value-Searchxinput type=hidden name-n 
30 value="25">   <a href="http : //search .my . yahoo . com/search/my/options" 
>Options</a></font></form></center><p> 
<center> 

<table border-0 cellspacing=0 cellpadding=2> 
<tr> 

3 5 <td align=center><font color="#OOOOOOa><b>Sections : </b>    </f ont></td> 

<td align^center bgcolor="#dcdcdc"><f ont 
color="#000000"><b>Front  Page</b></font></td> 
<td>  1   </td> 

<td align=center><a href =" /news/business/summary. html?v">Business</a></td> 

4 0 <td>  I   </td> 

<td align=center><a href =" /news/port folio_summary . html?v">Portfolios</a></td> 

<td>  I  </td> 
<td align-centerxa 

href-"/news/entertainment/s\ammary.html?v">Entertainment</a></td> 

4 5 <td>  I   </td> 

<td align=center><a href =" /news/ sports /summary . html?v">Sports</a></td> 

<td>  l </td> 

<td align=center><a href-" /news/technology/summary . html?v">Technology</a></td> 
</tr> 
50 </table> 
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</center> 
</center> 

5 <tabie border=l cellpadding=4 cellspacing=0 width='*100% '*> 
<tr><td align=center valign=top width'="l%"> 
<a 

href="http: //edit .my. yahoo, com/conf ig/eval_lef t ?mode=lef t_nsuin& . done=http%3a%2f %2 f 
my%2eyahoo%2ecom%2f news%2f suinrnary%2ehtml%3fv"><img border=0 
10 src="http: //www. yahoo. com/images/my/lef t . gif" alt^"edit left"></a> 
<table border=0 cellpadding=l cellspacing=0 width=" 100% "> 

<tr bgcolor^"#dcdcdc"><td colspan=4 width=" 100% "xtable border=0 cellpadding=-2 
cellspacing=0 width="100%"><tr><td width-" 100% "xbxfont si2e=" + l">p<f ont 
size="+0">ORTFOLIOS</font></font></b></td><td align=right><a 
15 href^"http: / /edit . my . yahoo . com/conf ig/eval_quotes ?. done=http : //my . yahoo . com/news/s 
ummary . html?v"><img align=absmiddle border=0 height=13 width=25 
src="http: / /www. yahoo . com/ images /my /personalize .gif" 
alt="edit"></a></td></tr></table></td></tr> 
<tr><td valign=top width="10% "Xnobrxa 

2 0 href="http: / /edit . my . yahoo . com/conf ig/set_portf_expand?port=Quotes&expand=Oi . done== 

http: //my. yahoo . com/news /summary . html ?v"><img align=absmiddle border=0 height=ll 
width=ll src="http: //www . yahoo . com/ images /my/arrowdown . gif " 
alt="edit"></a></td><td valign=top width="30% "xnobrxbxa 

href ="http: / / quote . yahoo. com/portfolio?view&key=pf_l">Quotes</ax/b></nobr></td><t 
25 d width="30%"></td><td width="30% "><big></td></tr> 

<tr><td align=left valign=top width="10% "xnobrxf ont size="- 

l">  <br>  <br>  <br>  <br>  <br>*<br>*<br>* <br>* <br>*<br></ f o 
ntx/nobrx/tdxtd valign=top width="30% "xnobrxf ont size="-l"xa 
href="http: / /quote . yahoo . com/quotes ?SYMBOLS="DJI&detailed=t">DJIA</axbr> 

3 0 <a href =^"http: //quote. yahoo. com/quotes?SYMBOLS="NYA&detailed=t">NYSE</a><br> 

<a href="http: //quote . yahoo. com/quotes?SYMBOLS='*IXIC&detailed=t">NASDAQ</a><br> 
<a href="http: / /quote . yahoo . com/quotes ?SYMBOLS='"SPX&detailed=t ">S&P 500</a><br> 
<a href==="http: //quote . yahoo . com/quotes?SYMBOLS=^XAX&detailed=t">AMEX</a><br> 
<a href="http: //quote. yahoo. com/ quotes?SYMBOLS=YHOO&detailed=t">YHOO</a><br> 

3 5 <a href="http: //quote . yahoo . com/ quotes ?SYMBOLS=NSCP&detailed=t">NSCP</a><br> 
<a href="http: / /quote .yahoo . com/quotes?.SYMBOLS=IOM&detailed=t">IOM</atf <br> 
<a href ="http: //quote .yahoo. com/quotes ?SYMBOLS=NSCP&detailed=t">NSCP</a><br> 
<a href ="http : //quote . yahoo . com/quotes ?SYMBOLS=YHOO&detailed=t">YHOO</a><br> 
</f ontx/nobrx/tdxtd align=right valign=top width=" 30% "xnobrxf ont size="- 

40 l">73l2.15<br>442.36<br>1384.91<br>845.48<br>609.02<br>32 l/2<br>29 l/4<br>19 
l/4<br>29 l/4<br>32 l/2<br></f ontx/nobrx/tdxtd align=right valign=top 
width=" 30% "Xnobrxf ont size="-l "><f ont size="-l" 
color="#007f 00">+22 . 75</f ontxbrxf ont size="-l" 
color-"#007f00">+0. 82</f ontxbrxf ont si2e="-l" color="#7 f 0000 

45 19. 88</fontxbrxfont size*"-!" color=" #7 f0000">-0 . 88</f ontxbrxf ont si2e="-l"- 
color="#007f 00">+l. 85</font><brxfont size="-l" color="#7 f 0000">- 
5/8</font><br><font size="-l" color-"#7f0000">-5/8</f ontxbrxf ont size="-l" 
color=" # 007 f00">+l/2</f ontxbrxf ont size=^"-l" color="#7 f 0000">- 
5/8</fontxbr><font si2e=^"-l" color="#7 f 0000">- 

50 5/8</font><brx/fontx/nobrx/td></tr> 

<tr><td align=center colspan=4 xf orm method=get 
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act:ion="http: //quote. yahoo. coiu/quotes**><font size="-l "xinput type=text size=10 
name=symbols>< input type=submit value="Get Quotes "xbrxfont si2e="0">quotes 
delayed 20 minutes - <a href =" /f in_disclaimer . html">disclaimer</a><br>click on 
symbol for detailed quote + news<br><b>*</b> indicates new news during last 
5 2 4hrs<font></form></td></tr></table> 

<hr si2e=0><table border=0 cellpadding=l cellspacing=0 width="100% "> 

<tr bgcolor="#dcdcdc"><td colspan=5 width="100%"><table border=0 cellpadding=2 

cellspacing=0 width="100% "xtrxtd width="100% "><a 

href =" /sum/ ?http: //sports . yahoo . com/ "xbxfont si2e=" + l">S<f ont 

10 si2e="+0">COREBOARD</font></font></b></a></td><td align=right><a 

href ="http : //edit .my . yahoo . com/conf ig/set_sports? . done^http : //my , yahoo, com/news/su 
mmary . html?v"><img align=absmiddle border=0 height-13 width==25 
src="http: //www . yahoo . com/ images/my/personali2e . gif " 
alt="edit"x/ax/td></tr></tablex/tdx/tr> 

15 <tr><td colspan=5xb><font size=*'-l ">TODAY</f ont></b></td></tr> 
<tr><td valign=top><f ont si2e=-l><a 

href="http: / /sports^. yahoo . com/al/ ">AL</a></ font x/tdxtd valign=top><f ont si2e=- 
l>Detroit<brXb>Oakland</b></font></td><td align=right valign^topxf ont size=- 
l>8<br>9</f ontx/tdxtd ■ valign=top>& #160 ; < /tdxtd valign=topXf ont size=-l><a 
2 0 href ="http: / /sports .yahoo. com/al/rcps/970 603/detoak.html">F</a></font></td></tr> 
<trxtd valign=topxf ont si2e=-l><a 

href ="http: / /sports . yahoo . com/nl/ ">NL</a></f ontx/tdxtd valign=topxf ont size=- 
l>San Francisco<br><b>Fiorida</b></font></td><td align=right valign=top><f ont 
si2e=-l>9<br>l</fontx/tdxtd valign=top>&# 160 ; </td><td valign-topxf ont size=- 

2 5 ixa 

href-"http: //sports, yahoo.com/nl/rcps/970603/sf of la. html">F</a></fontx/td></tr> 
<tr><td colspan=5xb><font size="-l">YESTERDAY</f ontx/bx/ tdx/tr> 
<trxtd valign=top><f ont si2e=-l><a 

href="http: //sports. yahoo. com/al/">AL</a></font></tdxtd valign=topXf ont size=- 

3 0 l>Detroit<br><b>Oakland</b></f ontx/tdxtd align=right valign=top><f ont si2e=- 

l>8<br>7</font></tdxtd valign=top>  </tdxtd valign=top><f ont si2e=^-lxa 
href ="http: //sports, yahoo. com/al/rcps/970602/detoak.html">F</aX/font></td></tr> 
<tr><td valign=top><f ont si2e=-lXa 

href="http: //sports . yahoo . com/nl/">NL</aX/font></td><td valign=top><f ont si2e=- 

3 5 l>San Francisco<brxb>Florida</b></f ontx/tdxtd align=right valign^topxf ont 

size=-l>2<br>4</f ontx/tdxtd \Fklign=top>&#l60 ; </td><td valign=top><f ont si2e=- 
ixa 

href-"http: //sports, yahoo.com/nl/rcps/970602/sf of la. html">F</ax/font></td></tr> 
</table> 

40 

<hr siz€=0><table border=0 cellpadding=2 cellspacing=0 width-" 100% "> 

<tr bgcolor="#dcdcdc"><td colspan=3 width-"100% "xtable border=0 cellpadding=2 

cellspacing=0 width="100%"><tr><td width="100% "><a 

href="/my/?http: / /weather . yahoo . com/ "xbxfont size=" + l">W<f ont 

4 5 si2e==" + 0">EATHER</fontx/fontx/b></ax/tdxtd aiign=rightxa 

href ^"http : / /edit .my . yahoo . com/conf ig/set_wni? . done^http : / /my . yahoo . com/news/summa 
ry.html?v"><img align^absmiddle border=0 height=13 width=25 
src-"http: //www. yahoo . com/images/my/personalize . gif" 
alt="edit"x/a></td></tr></tablex/td></tr> 

5 0 <t rxtdxa href ="http : / /weather . yahoo . com/ forecast /Augusta_GA_US_f . html"><f ont 

size="-l">Augusta, GA</f ontx/ax/tdxtd align=right><f ont size="-l">63. . .78 
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F</font></td><td align=right><f ont si2e="-l "xiitvg height=24 width«32 
src="http: //www. yahoo , com/ images /my /wni/ 87 . gif " alt="Showers "></f ont></td></tr> 
<tr><td><a href="http: //weather . yahoo . com/ f orecast/London_UK_f . html"><f ont size="- 
l">London, UK</f ontx/ax/tdxtd align=right><f ont si2e="-l ">50 . . . 73 
5 F</font></td><td align=right><font size="-l "ximg height^24 width=^32 

src="http: //www . yahoo . com/ images /my /wni/ 87 .gif" alt= " Showers "></font></tdx/tr> 
<tr><td><a href ="http : //weather . yahoo , com/ forecast /Oakland_CA_US_f . html"><f ont 
size="-l">Oakland, CA</f ontx/ax/tdxtd align=rightxf ont size="-l">59 . . .70 
F</f ontx/tdxtd align=right><f ont size=="-l"><img height=24 width=32 
10 src="http: //www. yahoo . com/ images/my/wni/66. gif " alt-"Partly 
Cloudy" x/font></td></tr> * 

<t:rxtd><a href="ht.tp: //weather . yahoo . com/f orecast/San_Jose_CA_US_f . htmi"><f ont 
size="-l">San Jose, CA</f ontx/ax/tdxtd align=right><f ont si2e="-l">54 . . . 75 
F</font></td><td align=rightxfont size="-l "ximg height=24 width^32 
15 src="http: / /www. yahoo.com/images/my/wni/82 .gif " alt="Rain"></ f ontx/tdx/tr> 
<tr><td align=center colspan=3><f ont size=0>click on city for extended 
f orecast</font></td></tr> 
</table> 

2 0 <hr size=0> 

<px/td> 

<td align=center valign=top width=" 100%"> 
<cent.er> 

<table border=l cellpadding=4 cellspacing=0 width="100% "> 
25 <tr> 

<td bgcolor="#000000"> 

<table border=0 cellpadding=0 cellspacing=0 width="100%"><t:r> 
<td align=left valign=bottomXf ont color=" # f f f f f f " 
si2e=" + l"xnobr><b>F</b></nobrx/font><font 

3 0 color="#f f f f f f "xb><nobr>RONT</nobr>  <nobr>PAGE</nobrx/b> - Jun 3 

7 : 40pm</fontx/td> 
<td align=right><a 

href ="http: / /edit .my . yahoo . com/con fig /edit__news? . hie r==News + Suminary% 3aEdit& . done=ht 
tp: //my .yahoo.com/news/summary .html?v"><img align=right border=0 height=15 

3 5 width=66 vspace=2 src="http : //www . yahoo . com/ images/my/edit_topics . gif " alt="edit 

topics"></ax/td></tr> ^ 

</table> 

</td> - 

</tr> 

4 0 </table> 

</center> 

<table border=l cellpadding=2 cellspacing=0 width="100% "> 

<tr><td bgcolor="#dcdcdc" colspan=2><a href =" /news/ top_stories . html?v"><b><f ont 
4 5 si2e=" + l">B</font>reaking News</b></a>  <i>Jun 3 5 : 03pm</ix/td></tr> 
<tr><td colspan=2xul> 

<li><a href="http: //www. yahoo . com/headlines/ 970 603/news/ stories /bombing_61 , html" 
> Judge Moves to Avoid McVeigh * Lynching * </a> 
<li><a href= 

50 "http: //www. yahoo. com/headlines/ 97 0 603/news /stories /bombingappeals_l. html ">McVeigh 
's Expected Appeals May Last Years</a> 
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<li><a 

href="http: //www . yahoo, com/headlines / 970603 /news /stories /bombingpenalty_l. html ">Ex 

perts: Plea for Mercy is McVeigh's Best Hope</a> 

</ul></td></tr> 

5 <tr><td bgcolor="#dcdcdc" colspan=2><a href =" /news/world . html ?v"><b><font 
size-" + l">W</font>orld</b></a>  <i>Jun 3 2 : 09pm</i></td></tr> 
<tr><td colspan=2><ul> 
<li><a 

href ="http: / /www. yahoo, com/headl ines/ 97 060 3 /international /stories /canada_6 .html" >C 
10 anadian Liberals Face Thorny Issues</a> 
<li><a 

href-"http: / /www. yahoo. com/headlines / 97 0603 /international /stories /nato_10. html" >U , 

S. Advocates Ready for NATO Expansion Fight</a> 

<li><a 

15 href="http: //www. yahoo. com/headlines/970603/international/stories/leone_ll .html">U 
.S. Ferries More Foreigners from Sierra Leone</a> 
</ul></td></tr> 

<tr><td bgcolor="#dcdcdc" colspan=2><a 

href ="http: //biz - yahoo. com/news/zOOOO . html"><b><font size=" + l">U</ f ont> . S . Stock 
20 News and Report</b></a>  <i></i></ td></tr> 
<tr><td colspan=2><ul> 

<li><a href="http: / /biz . yahoo . com/finance/ 97 /O 6/03 /crdm_y001_l . html ">Cardima Inc 
IPO range reduced - underwriter</a> 

<li><a href="http://bi2. yahoo. com/finance/97/06/03/luk_wtsc_l.html">AMEX to trade 

2 5 Leucadia, West TeleServices options</a> 

<li><a href="http://biz, yahoo. com/finance/97/06/03/acv_acva_l.html">CBOE to trade 

options on Alberto-Culver Class A</a> 

</ul></td></tr> 

<tr><td bgcolor="#dcdcdc" colspan=2><a href =" /news/sports/mlb . html ?v"><b><font 
30 si2e="+l">M</font>ajor League Baseball</b></a>  <i>Jun 3 5 : 15pm</i></td></tr> 
<tr><td colspan=2><ul> 

<li><a href="http: / /sports . yahoo . com/mlb/lgns/ 97 0 603 /draftlist , html ">1 997 baseball 
free agent draft first round selections</a> 

<li><a href="http: //sports. yahoo. com/nl/lgns/970603/nl3tars .html">Mike Piazza 

3 5 leads balloting in NL All-Star voting</a> 

<li><a href="http: //sports . yahoo . com/nl/lgns/970603/nlvotes . html">National League 

All-star voting results</a> 

</ul></td></tr> 

<tr><td bgcolor="#dcdcdc" colspan=2><a 
4 0 href="/news/entertainment/top_stories . html?v"><b><f ont 

size="+l">E</font>ntertainment Top Stories</b></a>  <i>Jun 3 
6 : 35pm</i></td></tr> 
<tr><td colspan=2><ul> 

<li><a href="http: //www . yahoo . com/headlines/970603 
45 /entertainment/summary_l .html#headline_l">Clinton Reflects on Music </a> 
<li><a href-"http : / /www . yahoo . com/headlines/970603 

/entertainment /summary_l.html#headline_2">Gif ford: Marriage is Solid </a> 
<li><a href="http: //www . yahoo . com/headlines/970 603 

/entertaininent/s\immary_l .html#headline_3">Rockabilly Legend Hospitalized </a> 
50 </ul></td></tr> 

<tr><td bgcolor^" #dcdcdc" colspan=2><a 
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href^'Vnews/entertainment/movies . html ?v"><b>< font size="+l ">M</f ont>ovies + 
Film</b></a>  <i>Jun 3 10 : 13am</i></td></tr> 
<tr><td colspan=^2><ul> 

<li><a href="http: //www. yahoo. com/headlines /970603/entertainment 
5 /stories/f ilm_cage_l.html">FEATURE: Nicolas Cage Asks, Where Are The Heroes?</a> 
<li><a href=^"http: //www . yahoo . com/headlines /970603/entertainment 
/stories/f ilm_cassavetes_l .html">Nick Cassavetes Updates Father's 'Bookie '</a> 
<li><a href="http: //www. yahoo. com/headlines / 97 060 3 /entertainment 
/stories/film_boxof fice_9.html Lost World' Props Up Slow Box Office</a> 
10 </ul></td></tr> 
</tabie> 

</td></tr> 
</table> 

15 

<center> 

<table border=l cellpadding=2 cellspacing=^0 width="100% "> 
<tr bgcolor="#fOf 8f f "> 

<td align=center colspah=2><tabl€ border=0 cellpadding=2 cellspacing=0 
20 width-"100%"> 

<tr><td align=lGft width="60%"><f ont size="-l"><b>TIP  </b> clicking on the My 
Yahoo i logo at the top will reload and update your default page - </f ontx/tdxtd 
align=center width="28%" nowrapxfont si2e="-l"><a 

href="http : //bwguide . yahoo . com/bwguide/start . html">Yahoo ! BackWeb Channel 

2 5 Guide</a><br><a href="http: //www . yahoo . com/docs/inf o/outreach/">Yahoo ! Community 

Relations</a></f ontxbrxbrxf ont si2e="-l"><a 

href="/niotn/?http: //local . yahoo. com/local/">Get Local</a> · <a 
href="/motn/?http: //my .yahoo, com/ticker .html">News Ticker</a> · <a 
href="/motn/?http: //fool . yahoo . com/ fool ">Mot ley FooK/ax/f ont></tdx/tr> 

3 0 </tablex/td> 

</tr> 
</table> 
</center> 
<P> 
3 5 <hr> 

<center> y 

<table border=0 cellpadding=^0 ceilspacing=0 width^"100% "> 

<tr> 

<td align=left valign=topxtable border=0 cellpadding^O cellspacing-0> 
40 <tr><td align=left valign==bottom><a href-" /my/ ?http : //www . yahoo . com/ "ximg 
border=0 height=47 width=47 src="http: //www . yahoo . com/images/my/yahoo . gif" 
alt=" Yahoo! "></ax/td> 
<td>   </td> 

<td align=left valign=bottom width="100% "Xf ont size'="-l "><i>Copyright © 
45 1994-1997 Yahoo! Inc. All rights reserved . </i><br>Portions copyright ficopy; 1997 
Reuters Ltd. All rights reserved . <br> 

Portions copyright © 1997 SportsTicker Enterprises LP. All rights 
reserved. <br> 

Portions copyright © 1997 Weathernews Inc. All rights reserved . <br> 
50 Portions copyright © 1997 Business Wire. All rights reserved . <br> 
Portions copyright © 1997 PR Newswire. All rights reserved. <br> 
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Questions, comments, or suggestions? Send us <a 

href="http: //my , yahoo, com/ feedback, html ">f eedback</a> . </f ont></td> 
</tr> 
</table> 
5 </td> 

<td>   </td> 

<td align=right><a href=" /bin/logout_menu"><img border=0 height=68 width=100 ismap 
usemap="# logout" src="http: / /www. yahoo . com/ images /my/ logout . gif" alt= "Change 
User"></a></td> 
10 </tr> 

</table> 

</center> 

<map name=logout> 

<area coords="0 , 0 , 50, 68" href =" /my/ ?http :/ /www . yahoo . com/ "> 
15 <area coords="51 , 0 , 100, 68" href ="http : //edit .my . yahoo . com/conf ig/login?logout==l "> 
</map> 

</body> 
</html> 
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WHAT IS CIAIMED IS : 

1 . A server system for serving a customized 
information page to a user at a browser on request, 
5 comprising: 

a database of user configurations; 
means for obtaining information from the user 
referencing a record in the database of user configurations, 
the record being a record for the user; 
10 means for generating a template based on the record 

for the user; 

a plurality of user processes, one process per user 
accessing the server system; 

a shared memory; 
15 a data structure within the shared memory for 

storing the dynamic information needed to generate the 
customized information page; and 

response means for responding to a request with an 
information page containing dynamic information from the data 

2 0 structure formatted according to the template generated for 

the user making the request . 

2. The server system of claim 1, wherein the 
plurality of user processes execute on a plurality of servers, 
25 the server system further comprising a means for assigning one 
of the plurality of servers to users who send requests to the 
server system but do not ^^Iready have an associated user 
process . 

3 0 3. The server system of claim 2, wherein the means 

for assigning servers is a means for assigning a specific 
server to a particular user, such that the particular user is 
assigned the specific server for each request. 

3 5 4. The server system of claim 3, further comprising 

a cache for caching templates for recently serviced users on 
each of the specific servers assigned to particular users. 



BNSDOCfD: <WO 9e57276AlJ_> 



wo 98/57276 



24 



PCT/US98/09782 



5. The server system of claim 1, further comprising 
a cache for caching templates for recently serviced users. 

6. The server system of claim 1, further comprising 
5 means for generating default user configurations based on user 

demographic information. 

7. The server system of claim 6, further comprising 
means for determining a default list of cities for a weather 

10 report and sports teams for sports reporting based on user 
demographic information . 

8. The server system of claim 7, wherein the means 
for determining the default list of cities and default lists 

15 of sports teams uses user postal code information, the server 
system further comprising: 

means for translating postal code information to 
user geographic position; 

means for comparing the user geographic position to 
20 geographic positions assigned to each city and sports team; 
and 

means for determining a threshold distance from the 
user geographic position which is greater than or equal to a 
distance to a predetermined nonzero number of cities and a 
2 5 predetermined nonzero number of sports team geographic 
positions . 

9. A method of serving custom news pages, 
comprising the steps of: 

30 collecting current security quotes for each of a 

plurality of selectable securities; 

collecting current sports news and scores for each 
of a plurality of selectable sports events; 

collecting current news headlines which reference 
35 news articles; 

formatting the current security quotes, current 
sports news and current news headlines into a data structure 
stored in a shared memory; 
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accepting a request for a custom page from a user; 

in response to the request, reading a user template 
for the user from a template database, wherein the user 
template describes a layout of a custom news page customized 
5 for the user; 

populating a page based on the read user template 
and the current data stored in the data structure in the 
shared memory to form a custom news page; and 

providing the custom news page to the user in real- 
10 time response to the request. 
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<html> 
<heaci> 

<title>My Yahoo! news summary for <!-- login 

</head> 

<body> 


— ></t it le> 


<center> 

< ! --banner : sum --> 




<! — ad --> 




C<1 — nav bar -->) — 302 
</cent:Gr> 




<table border=l eel lpadding=4 eel lspacing=0 
<tr><td align=center. valign=top width="l%"> 
C<! — left side : nsum -->)~302 


width=100%"> 


<p></td> 

<td align=eenter valign=top width=" 1 00%"> 
<! — mode bar : "FRONT PAGE" — > 
(^<!-- channel:nsum 3 — -302 




</td></tr> 
</table> 




<eenter> 

<table border=l cellpadding=2 eel lspacing=0 

<! — motdimotn .html — > 

</table> 

</cent er> 

< ! — search — > 


width=100%"> 


<! — copyright : sum — > 




</body> 
</htm.l> 





204 

FIG. 3. 
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